/**
 * Mobile Optimization CSS
 * تحسينات الهاتف والتابلت
 */

:root {
  --touch-target: 44px;
}

/* عناصر قابلة للمس مريحة */
button,
a[href],
input[type="button"],
input[type="submit"],
input[type="reset"] {
  min-height: var(--touch-target);
  min-width: var(--touch-target);
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

a {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0.08);
}

/* الشاشات المتوسطة */
@media (max-width: 1024px) {
  .card {
    flex: 0 1 calc(50% - 8px);
  }
}

/* الموبايل */
@media (max-width: 768px) {
  input,
  textarea,
  select {
    font-size: 16px; /* منع zoom التلقائي على iOS */
    width: 100%;
  }

  img {
    max-width: 100%;
    height: auto;
    display: block;
  }

  .thumbnail {
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
  }
}

/* Floating quick nav */
@media (max-width: 640px) {
  .fab-nav {
    right: max(10px, env(safe-area-inset-right));
    bottom: max(10px, env(safe-area-inset-bottom));
    z-index: 10000;
  }

  .fab-menu {
    width: 42px;
    height: 42px;
    font-size: 16px;
  }

  .fab-menu-circle {
    width: calc(100vw - (2 * var(--fab-gap-x)));
    max-width: none;
    max-height: 60vh;
    border-radius: 14px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 10px;
    overflow: auto;
  }

  .fab-menu-circle .fab-item {
    width: 100%;
    min-height: 42px;
    height: auto;
    font-size: 11px;
    padding: 8px;
    border-radius: 10px;
  }

  .fab-menu-circle .fab-item i {
    font-size: 14px;
    margin-bottom: 0;
  }
}

@media (max-width: 480px) {
  body {
    font-size: 14px;
  }

  .main-header {
    padding: 8px 12px;
  }
}

@media (max-height: 500px) and (orientation: landscape) {
  .fab-menu-circle {
    max-height: 75vh;
  }
}

@supports (padding: max(0px)) {
  body {
    padding-left: max(0px, env(safe-area-inset-left));
    padding-right: max(0px, env(safe-area-inset-right));
  }
}

@media print {
  .fab-menu,
  .fab-menu-circle,
  header,
  nav {
    display: none !important;
  }
}
